package com.ljy.my_study.leetcode.可被5整除的二进制前缀;

import java.sql.SQLOutput;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

/**
 * @author lijunying
 * @date 2021/1/14 10:26
 */
public class TestMain {

//    给定由若干 0 和 1 组成的数组 A。我们定义 N_i：从 A[0] 到 A[i] 的第 i 个子数组被解释为一个二进制数（从最高有效位到最低有效位）。
//
//    返回布尔值列表 answer，只有当 N_i 可以被 5 整除时，答案 answer[i] 为 true，否则为 false。
//
//             
//
//    示例 1：
//
//    输入：[0,1,1]
//    输出：[true,false,false]
//    解释：
//    输入数字为 0, 01, 011；也就是十进制中的 0, 1, 3 。只有第一个数可以被 5 整除，因此 answer[0] 为真。
//    示例 2：
//
//    输入：[1,1,1]
//    输出：[false,false,false]
//    示例 3：
//
//    输入：[0,1,1,1,1,1]
//    输出：[true,false,false,false,true,false]
//    示例 4：
//
//    输入：[1,1,1,0,1]
//    输出：[false,false,false,false,false]
//             
//
//    提示：
//
//            1 <= A.length <= 30000
//    A[i] 为 0 或 1
//
//    来源：力扣（LeetCode）
//    链接：https://leetcode-cn.com/problems/binary-prefix-divisible-by-5

    public static void main(String[] args) {
        int[] array={1,0,1,1,1,1,0,0,0,0,1,0,0,0,0,0,1,0,0,1,1,1,1,1,0,0,0,0,1,1,1,0,0,0,0,0,1,0,0,0,1,0,0,1,1,1,1,1,1,0,1,1,0,1,0,0,0,0,0,0,1,0,1,1,1,0,0,1,0};
        System.out.println(new TestMain().prefixesDivBy5(array));
    }

    static List<Boolean> array=changeStr2List();

    private static List<Boolean> changeStr2List(){
        return Arrays.asList(new Boolean[]{false,false,true,false,false,false,false,false,false,false,true,true,true,true,true,true,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,false,true,false,false,false,true,false,false,true,false,false,true,true,true,true,true,true,true,false,false,true,false,false,false,false,true,true});
//                                        [false,false,false,false,false,false, false, false, false, false, false,false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, true, false, false, true, true, true, true, false]
    }

    public List<Boolean> prefixesDivBy5(int[] A) {
        System.out.println(array);
        List<Boolean> result=new ArrayList<>();
        long num=0;
        for(int i=0;i<A.length;i++){
            num=((num<<1)+A[i])%5;
            boolean flag=(num%5==0);
            if(flag!=array.get(i)){
                System.out.println(num);
            }
            result.add(flag);
        }
        return result;
    }
}
